package com.arsn.myf.system.mapper;

import com.arsn.myf.common.node.TreeNode;
import com.arsn.myf.system.entity.Role;
import com.arsn.myf.system.vo.RoleVO;
import com.baomidou.mybatisplus.annotation.SqlParser;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.apache.ibatis.annotations.MapKey;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
import java.util.Map;

/**
 * 角色mapper 映射层
 * @author zhongrj
 * @time 2021-9-10
 */
@Mapper
public interface RoleMapper extends BaseMapper<Role> {
    /**
     * 自定义角色分页数据
     * @param page
     * @param role
     * @return
     */
    @MapKey(value = "id")
    @SqlParser(filter = true)
    Map<Long,RoleVO> selectPageRoleList(@Param("role") RoleVO role);

    /**
     * 查询角色列表
     * @param role
     * @return
     */
    List<RoleVO> getRoleList(@Param("role") RoleVO role);


    /**
     * 获取角色树
     * @param role 角色查询参数对象
     * @return
     */
    @MapKey(value = "id")
    @SqlParser(filter = true)
    Map<Long, TreeNode> getRoleTree(@Param("role") RoleVO role);

    /**
     * 根据角色id 查询对应菜单id集合
     * @param roleId 角色id
     * @return
     */
    List<Long> getRoleMenuList(@Param("roleId") String roleId);
}
